// =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-==-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= // // »Project« Talina Gaming System (TgS) (∂) // »File« TgS Common - Math API [Matrix] [M] [F].h_inc // »Author« Andrew Aye (EMail: mailto:andrew.aye@gmail.com, Web: http://www.andrewaye.com) // »Version« 4.0 // ------------------------------------------------------------------------------------------------------------------------------ // // Copyright: © 2002-2010, Andrew Aye. All Rights Reserved. // This software is free for non-commercial use. Redistribution and use in source and binary forms, with or without modification, // are permitted provided that the following conditions are met: // Redistributions of source code must retain this copyright notice, this list of conditions and the following disclaimers. // Redistributions in binary form must reproduce this copyright notice, this list of conditions and the following // disclaimers in the documentation and other materials provided with the distribution. // Neither the names of the copyright owner nor the names of its contributors may be used to endorse or promote products derived // from this software without specific prior written permission. // The intellectual property rights of the algorithms used reside with Andrew Aye. You may not use this software, in whole or // in part, in support of any commercial product without the express written consent of the author. // There is no warranty or other guarantee of fitness of this software for any purpose. It is provided solely "as is". // =-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-==-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= // // General Matrix Implementation // Per-Vector Arithmetic Operations TgINLINE TgVOID M(M_ADD_MM)( M(PCU_TgMAT), M(CPCU_TgMAT), M(CPCU_TgMAT) ); TgINLINE TgVOID M(M_MUL_MM)( M(PCU_TgMAT), M(CPCU_TgMAT), M(CPCU_TgMAT) ); TgINLINE TgVOID M(M_MUL_SM)( M(PCU_TgMAT), V4(C_TgVEC_M), M(CPCU_TgMAT) ); TgINLINE TgVOID M(M_MUL_MS)( M(PCU_TgMAT), M(CPCU_TgMAT), V4(C_TgVEC_M) ); TgINLINE TgVOID M(M_DIV_MM)( M(PCU_TgMAT), M(CPCU_TgMAT), M(CPCU_TgMAT) ); TgINLINE TgVOID M(M_DIV_SM)( M(PCU_TgMAT), V4(C_TgVEC_M), M(CPCU_TgMAT) ); TgINLINE TgVOID M(M_DIV_MS)( M(PCU_TgMAT), M(CPCU_TgMAT), V4(C_TgVEC_M) ); TgINLINE TgVOID M(M_SUB_MM)( M(PCU_TgMAT), M(CPCU_TgMAT), M(CPCU_TgMAT) ); TgINLINE TgVOID M(M_NEG_MM)( M(PCU_TgMAT), M(CPCU_TgMAT) ); // Matrix Specific Implementation // Load/Set Operations TgINLINE TgVOID M(M_CLI)( M(PCU_TgMAT) ); // Matrix Arithmetic Operations TgVOID M(M_CAT)( M(PCU_TgMAT), M(CPCU_TgMAT), M(CPCU_TgMAT) ); // Inverse Functions TgVOID M(M_INV_DET)( M(PCU_TgMAT), V4(C_TgVEC_M), M(CPCU_TgMAT) ); TgINLINE TgVOID M(M_INV)( M(PCU_TgMAT), M(CPCU_TgMAT) ); V4(TgVEC_M) M(M_DET)( M(CPCU_TgMAT) ); // Transformation TgINLINE V4(TgVEC_M) M(M_TX_V4)( M(CPCU_TgMAT), V4(C_TgVEC_M) ); // Get Basis TgINLINE V4(TgVEC_M) M(M_GET_COL_0_V4)( M(CPCU_TgMAT) ); TgINLINE V4(TgVEC_M) M(M_GET_COL_1_V4)( M(CPCU_TgMAT) ); TgINLINE V4(TgVEC_M) M(M_GET_COL_2_V4)( M(CPCU_TgMAT) ); TgINLINE V4(TgVEC_M) M(M_GET_COL_3_V4)( M(CPCU_TgMAT) );